<?php
/**
 * @package Admin
 * @author Henrique Droog <henridroog@gmail.com>
 * @name CategoriaMapper
 * @since 12/03/2011
 * @version 1.0
 */
class Admin_Model_CategoriaMapper {

    protected $_dbTable;

    public function setDbTable($dbTable) {
        if (is_string($dbTable)) {
            $dbTable = new $dbTable();
        }
        if (!$dbTable instanceof Zend_Db_Table_Abstract) {
            throw new Exception('Invalid table data gateway provided');
        }
        $this->_dbTable = $dbTable;
        return $this;
    }

    public function getDbTable() {
        if (null === $this->_dbTable) {
            $this->setDbTable('Admin_Model_DbTable_Categoria');
        }
        return $this->_dbTable;
    }

    public function save(Admin_Model_Categoria $categoria) {
        $data = array(
            'categoria_titulo' => $categoria->getTitulo(),
            'categoria_descricao' => $categoria->getDescricao(),
            'categoria_ativo' => $categoria->getAtivo(),
            'categoria_ordem' => $categoria->getOrdem(),
        );
//        if ($categoria->getId()<=0)
//                $categoria->setId ("NULL");
        //if (null === ($id = $categoria->getId())) {
        if ($categoria->getId()<=0) {
            unset($data['categoria_id']);
            $this->getDbTable()->insert($data);
        } else {
            $this->getDbTable()->update($data, array('categoria_id = ?' => $categoria->getId()));
        }
    }

    public function find($id, Admin_Model_Categoria $categoria) {
        $result = $this->getDbTable()->find($id['id']);
//        echo "<pre> Find:";
//        print_r($result);
//        echo "</pre>";
        if (0 == count($result)) {
            return;
        }
        $row = $result->current();
        $categoria->setId($row->categoria_id)
                  ->setTitulo($row->categoria_titulo)
                  ->setDescricao($row->categoria_descricao)
                  ->setAtivo($row->categoria_ativo)
                  ->setOrdem($row->categoria_ordem);
        return $categoria;
    }

    public function fetchAll(){
        $resultSet = $this->getDbTable()->fetchAll();
        $entries = array();
        foreach ($resultSet as $row) {
            $entry = new Admin_Model_Categoria();
            $entry->setId($row->categoria_id)
                    ->setTitulo($row->categoria_titulo)
                    ->setDescricao($row->categoria_descricao)
                    ->setAtivo($row->categoria_ativo)
                    ->setOrdem($row->categoria_ordem);
            $entries[] = $entry;
        }
        return $entries;
    }
    //
    public function del(Admin_Model_Categoria $categoria){
        $where = array("categoria_id = ?" =>$categoria->getId());
        $resultSet = $this->getDbTable()->delete($where);
        return $resultSet;
    }

}